import type { RouteRecordRaw } from 'vue-router';
import type { App } from 'vue';
import { createRouter, createWebHistory } from 'vue-router';
import { basicRoutes } from './routes';
import { uimsLogin } from '@/utils/uims';
import { getToken } from '@/utils/cookie';
import { isEmpty } from '@/utils/is';

import { useUserStore } from '@/store/modules/user';
// 白名单应该包含基本静态路由
const WHITE_NAME_LIST: string[] = [];
const getRouteNames = (array: any[]) =>
  array.forEach((item) => {
    WHITE_NAME_LIST.push(item.name);
    getRouteNames(item.children || []);
  });
getRouteNames(basicRoutes);
const whiteList = ['/h5/sign', '/h5/outbound'];
// app router
// 创建一个可以被 Vue 应用程序使用的路由实例
export const router = createRouter({
  // 创建一个 hash 历史记录。
  history: createWebHistory(import.meta.env.VITE_PUBLIC_PATH),
  // 应该添加到路由的初始路由列表。
  routes: basicRoutes as unknown as RouteRecordRaw[],
  // 是否应该禁止尾部斜杠。默认为假
  strict: true,
  scrollBehavior: () => ({ left: 0, top: 0 }),
});

router.beforeEach((to, from, next) => {
  if (whiteList.includes(to.path)) {
    // console.log(to.name);

    next();
    // next();
    return;
  }

  if (!getToken()) {
    uimsLogin();
  } else {
    const userStore = useUserStore();

    if (isEmpty(userStore.userInfo)) {
      userStore.getUserInfoAction();
    }
    next();
  }

  // next();
});

// reset router
export function resetRouter() {
  router.getRoutes().forEach((route) => {
    const { name } = route;
    if (name && !WHITE_NAME_LIST.includes(name as string)) {
      router.hasRoute(name) && router.removeRoute(name);
    }
  });
}
// 配置路由器
export function setupRouter(app: App<Element>) {
  app.use(router);
}
